**Design Challenges**

***Challenge #1:***

Design of an LFSR

A linear feedback shift register (LFSR) is a shift register whose input bit is the output of a linear function of two or more of its previous states (taps). An LFSR of length m consists of m stages numbered 0 , 1 , … , m − 1 , each capable of storing one bit, and a clock controlling data exchange. It generally has a seed value that can be loaded into it in the beginning and it circles through a series of states.

An example is given below:

![IMG_256](data:image/png;base64,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)

***Challenge #2:***

Design an ALU

The specifications are given below:

| 0000 | ALU\_Out = A + B;

----------------------------------------------------------------------

| 0001 | ALU\_Out = A - B;

----------------------------------------------------------------------

| 0010 | ALU\_Out = A \* B;

----------------------------------------------------------------------

| 0011 | ALU\_Out = A / B;

----------------------------------------------------------------------

| 0100 | ALU\_Out = A << 1;

----------------------------------------------------------------------

| 0101 | ALU\_Out = A >> 1;

----------------------------------------------------------------------

| 0110 | ALU\_Out = A rotated left by 1;

----------------------------------------------------------------------

| 0111 | ALU\_Out = A rotated right by 1;

----------------------------------------------------------------------

| 1000 | ALU\_Out = A and B;

----------------------------------------------------------------------

| 1001 | ALU\_Out = A or B;

----------------------------------------------------------------------

| 1010 | ALU\_Out = A xor B;

----------------------------------------------------------------------

| 1011 | ALU\_Out = A nor B;

----------------------------------------------------------------------

| 1100 | ALU\_Out = A nand B;

----------------------------------------------------------------------

| 1101 | ALU\_Out = A xnor B;

----------------------------------------------------------------------

| 1110 | ALU\_Out = 1 if A>B else 0;

----------------------------------------------------------------------

| 1111 | ALU\_Out = 1 if A=B else 0;

A sample of verilog module configuration is given below:

**module** alu(

**input** [**7**:**0**] **A**,**B**, // ALU 8-bit Inputs

**input** [**3**:**0**] ALU\_Sel, // ALU Selection

**output** [**7**:**0**] ALU\_Out, // ALU 8-bit Output

**output** CarryOut // Carry Out Flag

);

***Challenge #3:***

Design a state machine to detect a given input 3-bit sequence in a 32-bit sequence

32 bit

seq\_detector

seq\_found

3 bit

In the given 32 bit sequence should be traversed serially and when ever the 3-bit sequence is detected the seq\_found should be asserted HIGH. When writing a test bench for the above design, a counter logic should be implemented to count the number of seq\_found signals generated. Also, a logic can be implemented in the test bench to automatically verify if the seq\_detector is working as expected.

***Challenge #4:***

Design a clock with HH:MM:SS format

The clock should count from 00:00:00 to 23:59:59

***Challenge #5:***

Design the following micro-architecture

Control Logic

Shifter

Counter

The following are the requirements:

1. Both shifter and counter have the parallel load feature and they are 8 bit
2. When the counter reaches a given count value one bit in the shifter should be shifted out serially
3. When all the bits are shifted out, then the entire process can begin again
4. Data can be loaded to shifter externally, however, once the shifting starts, the next data can be input to the shifter only after all the bits are shifted out.

Design the control logic as needed to meet all the requirements above.

Also, come up with the input and output signals as per the requirement for the top level module.